Table 44-2. Standard Instruction Set

| Mnemonic,<br>Operands |                                 | Description                                                                |           |            | 16-Bit Instr                                                | Status                                                      |                                                             |                 |         |
|-----------------------|---------------------------------|----------------------------------------------------------------------------|-----------|------------|-------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|-----------------|---------|
|                       |                                 |                                                                            | Cycles    | MSb        |                                                             |                                                             | LSb                                                         | Affected        | Notes   |
|                       |                                 | ВҮТ                                                                        | E-ORIENTE | D FILE REG | ISTER INSTRU                                                | CTIONS                                                      |                                                             |                 |         |
| ADDWF                 | f, d, a                         | Add WREG and f                                                             | 1         | 0010       | 01da                                                        | ffff                                                        | ffff                                                        | C, DC, Z, OV, N | 1       |
| ADDWFC                | f, d, a                         | Add WREG and Carry bit to f                                                | 1         | 0010       | 00da                                                        | ffff                                                        | ffff                                                        | C, DC, Z, OV, N | 1       |
| ANDWF                 | f, d, a                         | AND WREG with f                                                            | 1         | 0001       | 01da                                                        | ffff                                                        | ffff                                                        | Z, N            | 1       |
| CLRF                  | f, a                            | Clear f                                                                    | 1         | 0110       | 101a                                                        | ffff                                                        | ffff                                                        | Z               |         |
| COMF                  | f, d, a                         | Complement f                                                               | 1         | 0001       | 11da                                                        | ffff                                                        | ffff                                                        | Z, N            | 1       |
| DECF                  | f, d, a                         | Decrement f                                                                | 1         | 0000       | 01da                                                        | ffff                                                        | ffff                                                        | C, DC, Z, OV, N | 1       |
| INCF                  | f, d, a                         | Increment f                                                                | 1         | 0010       | 10da                                                        | ffff                                                        | ffff                                                        | C, DC, Z, OV, N | 1       |
| IORWF                 | f, d, a                         | Inclusive OR WREG with f                                                   | 1         | 0001       | 00da                                                        | ffff                                                        | ffff                                                        | Z, N            | 1       |
| MOVF                  | f, d, a                         | Move f to WREG or f                                                        | 1         | 0101       | 00da                                                        | ffff                                                        | ffff                                                        | Z, N            | 1       |
| MOVEE                 |                                 | Move f <sub>s</sub> (12-bit source)                                        |           | 1100       | fsfsfsfs                                                    | fsfsfsfs                                                    | f <sub>s</sub> f <sub>s</sub> f <sub>s</sub> f <sub>s</sub> | None            | 4.0.4   |
| MOVFF                 | f <sub>s</sub> , f <sub>d</sub> | to f <sub>d</sub> (12-bit destination)                                     | 2         | 1111       | f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> | f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> | f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> f              |                 | 1, 3, 4 |
|                       |                                 | Move f <sub>s</sub> (14-bit source) to f <sub>d</sub> (14-bit destination) |           | 0000       | 0000                                                        | 0110                                                        | f <sub>s</sub> f <sub>s</sub> f <sub>s</sub> f <sub>s</sub> | None            |         |
| MOVFFL                | f <sub>s</sub> , f <sub>d</sub> |                                                                            | 3         | 1111       | $f_sf_sf_sf_s$                                              | fsfsfsfs                                                    | f <sub>s</sub> f <sub>s</sub> f <sub>d</sub> f <sub>d</sub> |                 | 1, 3    |
|                       |                                 |                                                                            |           | 1111       | f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> | f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> f              | f <sub>d</sub> f <sub>d</sub> f <sub>d</sub> f              |                 |         |
| MOVWF                 | f, a                            | Move WREG to f                                                             | 1         | 0110       | 111a                                                        | ffff                                                        | ffff                                                        | None            |         |
| MULWF                 | f, a                            | Multiply WREG with f                                                       | 1         | 0000       | 001a                                                        | ffff                                                        | ffff                                                        | None            | 1       |
| NEGF                  | f, a                            | Negate f                                                                   | 1         | 0110       | 110a                                                        | ffff                                                        | ffff                                                        | C, DC, Z, OV, N | 1       |
| RLCF                  | f, d, a                         | Rotate Left f through Carry                                                | 1         | 0011       | 01da                                                        | ffff                                                        | ffff                                                        | C, Z, N         | 1       |
| RLNCF                 | f, d, a                         | Rotate Left f (No Carry)                                                   | 1         | 0100       | 01da                                                        | ffff                                                        | ffff                                                        | Z, N            | 1       |
| RRCF                  | f, d, a                         | Rotate Right f through Carry                                               | 1         | 0011       | 00da                                                        | ffff                                                        | ffff                                                        | C, Z, N         | 1       |
| RRNCF                 | f, d, a                         | Rotate Right f (No Carry)                                                  | 1         | 0100       | 00da                                                        | ffff                                                        | ffff                                                        | Z, N            | 1       |
| SETF                  | f, a                            | Set f                                                                      | 1         | 0110       | 100a                                                        | ffff                                                        | ffff                                                        | None            |         |

PIC18F27/47/57Q43 Instruction Set Summary

| continu | ed      |                                  |           |                         |              |        |      |                 |       |
|---------|---------|----------------------------------|-----------|-------------------------|--------------|--------|------|-----------------|-------|
| Mnemo   |         |                                  |           | 16-Bit Instruction Word |              |        |      | Status          |       |
| Opera   | nds     | Description                      | Cycles    | MSb                     |              |        | LSb  | Affected        | Notes |
| SUBFWB  | f, d, a | Subtract f from WREG with Borrow | 1         | 0101                    | 01da         | ffff   | ffff | C, DC, Z, OV, N | 1     |
| SUBWF   | f, d, a | Subtract WREG from f             | 1         | 0101                    | 11da         | ffff   | ffff | C, DC, Z, OV, N | 1     |
| SUBWFB  | f, d, a | Subtract WREG from f with Borrow | 1         | 0101                    | 10da         | ffff   | ffff | C, DC, Z, OV, N | 1     |
| SWAPF   | f, d, a | Swap nibbles in f                | 1         | 0011                    | 10da         | ffff   | ffff | None            | 1     |
| XORWF   | f, d, a | Exclusive OR WREG with f         | 1         | 0001                    | 10da         | ffff   | ffff | Z, N            | 1     |
|         |         |                                  | BYTE-OR   | IENTED SKIF             | NSTRUCTIO    | NS     |      |                 |       |
| CPFSEQ  | f, a    | Compare f with WREG, skip if =   | 1 – 4     | 0110                    | 001a         | ffff   | ffff | None            | 1, 2  |
| CPFSGT  | f, a    | Compare f with WREG, skip if >   | 1 – 4     | 0110                    | 010a         | ffff   | ffff | None            | 1, 2  |
| CPFSLT  | f, a    | Compare f with WREG, skip if <   | 1 – 4     | 0110                    | 000a         | ffff   | ffff | None            | 1, 2  |
| DECFSZ  | f, d, a | Decrement f, Skip if 0           | 1 – 4     | 0010                    | 11da         | ffff   | ffff | None            | 1, 2  |
| DCFSNZ  | f, d, a | Decrement f, Skip if Not 0       | 1 – 4     | 0100                    | 11da         | ffff   | ffff | None            | 1, 2  |
| INCFSZ  | f, d, a | Increment f, Skip if 0           | 1 – 4     | 0011                    | 11da         | ffff   | ffff | None            | 1, 2  |
| INFSNZ  | f, d, a | Increment f, Skip if Not 0       | 1 – 4     | 0100                    | 10da         | ffff   | ffff | None            | 1, 2  |
| TSTFSZ  | f, a    | Test f, skip if 0                | 1 – 4     | 0110                    | 011a         | ffff   | ffff | None            | 1, 2  |
|         |         | BI                               | T-ORIENTE | D FILE REGIS            | STER INSTRUC | CTIONS |      |                 |       |
| BCF     | f, b, a | Bit Clear f                      | 1         | 1001                    | bbba         | ffff   | ffff | None            | 1     |
| BSF     | f, b, a | Bit Set f                        | 1         | 1000                    | bbba         | ffff   | ffff | None            | 1     |
| BTG     | f, b, a | Bit Toggle f                     | 1         | 0111                    | bbba         | ffff   | ffff | None            | 1     |
|         |         |                                  | BIT-ORII  | ENTED SKIP              | INSTRUCTION  | 1S     |      |                 |       |
| BTFSC   | f, b, a | Bit Test f, Skip if Clear        | 1 – 4     | 1011                    | bbba         | ffff   | ffff | None            | 1, 2  |

.....continued

| Mnemonic,<br>Operands |         | Description                  | Cycles |             | 16-Bit Instr | Status |      |                   |       |
|-----------------------|---------|------------------------------|--------|-------------|--------------|--------|------|-------------------|-------|
|                       |         |                              |        | MSb         |              |        | LSb  | Affected          | Notes |
| BTFSS                 | f, b, a | Bit Test f, Skip if Set      | 1 – 4  | 1010        | bbba         | ffff   | ffff | None              | 1, 2  |
|                       |         |                              | CO     | NTROL INSTI | RUCTIONS     |        |      |                   |       |
| ВС                    | n       | Branch if Carry              | 1 – 2  | 1110        | 0010         | nnnn   | nnnn | None              | 2     |
| BN                    | n       | Branch if Negative           | 1 – 2  | 1110        | 0110         | nnnn   | nnnn | None              | 2     |
| BNC                   | n       | Branch if Not Carry          | 1 – 2  | 1110        | 0011         | nnnn   | nnnn | None              | 2     |
| BNN                   | n       | Branch if Not Negative       | 1 – 2  | 1110        | 0111         | nnnn   | nnnn | None              | 2     |
| BNOV                  | n       | Branch if Not Overflow       | 1 – 2  | 1110        | 0101         | nnnn   | nnnn | None              | 2     |
| BNZ                   | n       | Branch if Not Zero           | 1 – 2  | 1110        | 0001         | nnnn   | nnnn | None              | 2     |
| BOV                   | n       | Branch if Overflow           | 1 – 2  | 1110        | 0100         | nnnn   | nnnn | None              | 2     |
| BRA                   | n       | Branch Unconditionally       | 2      | 1101        | 0nnn         | nnnn   | nnnn | None              | 2     |
| BZ                    | n       | Branch if Zero               | 1 – 2  | 1110        | 0000         | nnnn   | nnnn | None              | 2     |
| CALL                  | k, s    | Call subroutine              | 2      | 1110        | 110s         | kkkk   | kkkk | None              | 0.0   |
| CALL                  |         |                              | 2      | 1111        | kkkk         | kkkk   | kkkk |                   | 2, 3  |
| CALLW                 | _       | Call subroutine using WREG   | 2      | 0000        | 0000         | 0001   | 0100 | None              | 2     |
| СОТО                  |         |                              | 0      | 1110        | 1111         | kkkk   | kkkk | None              | 3     |
| GOTO                  | k       | Go to address                | 2      | 1111        | kkkk         | kkkk   | kkkk |                   |       |
| RCALL                 | n       | Relative Call                | 2      | 1101        | 1nnn         | nnnn   | nnnn | None              | 2     |
| RETFIE                | S       | Return from interrupt enable | 2      | 0000        | 0000         | 0001   | 000s | INTCONx STAT bits | 2     |
| RETLW                 | k       | Return with literal in WREG  | 2      | 0000        | 1100         | kkkk   | kkkk | None              | 2     |
| RETURN                | s       | Return from Subroutine       | 2      | 0000        | 0000         | 0001   | 001s | None              | 2     |
|                       |         |                              | INH    | ERENT INST  | RUCTIONS     |        |      |                   |       |
| CLRWDT                | _       | Clear Watchdog Timer         | 1      | 0000        | 0000         | 0000   | 0100 | TO, PD            |       |

PIC18F27/47/57Q43 Instruction Set Summary

| continue | ed                 |                                                 |        |            |              |                                  |      |                 |       |
|----------|--------------------|-------------------------------------------------|--------|------------|--------------|----------------------------------|------|-----------------|-------|
| Mnemo    |                    |                                                 |        |            | 16-Bit Instr | Status                           |      |                 |       |
| Operar   | ius                | Description                                     | Cycles | MSb        |              |                                  | LSb  | Affected        | Notes |
| DAW      | _                  | Decimal Adjust WREG                             | 1      | 0000       | 0000         | 0000                             | 0111 | С               |       |
| NOP      | _                  | No Operation                                    | 1      | 0000       | 0000         | 0000                             | 0000 | None            |       |
| NOP      | _                  | No Operation                                    | 1      | 1111       | xxxx         | XXXX                             | xxxx | None            | 3     |
| POP      | _                  | Pop top of return stack (TOS)                   | 1      | 0000       | 0000         | 0000                             | 0110 | None            |       |
| PUSH     | _                  | Push top of return stack (TOS)                  | 1      | 0000       | 0000         | 0000                             | 0101 | None            |       |
| RESET    | _                  | Software device Reset                           | 1      | 0000       | 0000         | 1111                             | 1111 | All             |       |
| SLEEP    | _                  | Go into Standby mode                            | 1      | 0000       | 0000         | 0000                             | 0011 | TO, PD          |       |
|          |                    |                                                 | LIT    | ERAL INSTR | UCTIONS      |                                  |      |                 |       |
| ADDFSR   | f <sub>n</sub> , k | Add FSR (f <sub>n</sub> ) with literal (k)      | 1      | 1110       | 1000         | f <sub>n</sub> f <sub>n</sub> kk | kkkk | None            |       |
| ADDLW    | k                  | Add literal and WREG                            | 1      | 0000       | 1111         | kkkk                             | kkkk | C, DC, Z, OV, N |       |
| ANDLW    | k                  | AND literal with WREG                           | 1      | 0000       | 1011         | kkkk                             | kkkk | Z, N            |       |
| IORLW    | k                  | Inclusive OR literal with WREG                  | 1      | 0000       | 1001         | kkkk                             | kkkk | Z, N            |       |
| LEOD     | £ 1.               | Load FSR(f <sub>n</sub> ) with a 14-bit         | 0      | 1110       | 1110         | 00f <sub>n</sub> f <sub>n</sub>  | kkkk | None            | _     |
| LFSR     | f <sub>n</sub> , k | literal (k)                                     | 2      | 1111       | 00kk         | kkkk                             | kkkk |                 | 3     |
| MOVLB    | k                  | Move literal to BSR<5:0>                        | 1      | 0000       | 0001         | 00kk                             | kkkk | None            |       |
| MOVLW    | k                  | Move literal to WREG                            | 1      | 0000       | 1110         | kkkk                             | kkkk | None            |       |
| MULLW    | k                  | Multiply literal with WREG                      | 1      | 0000       | 1101         | kkkk                             | kkkk | None            |       |
| RETLW    | k                  | Return with literal in WREG                     | 2      | 0000       | 1100         | kkkk                             | kkkk | None            |       |
| SUBFSR   | f <sub>n</sub> , k | Subtract literal (k) from FSR (f <sub>n</sub> ) | 1      | 1110       | 1001         | f <sub>n</sub> f <sub>n</sub> kk | kkkk | None            |       |
| SUBLW    | k                  | Subtract WREG from literal                      | 1      | 0000       | 1000         | kkkk                             | kkkk | C, DC, Z, OV, N |       |

PIC18F27/47/57Q43 Instruction Set Summary

| 2. | If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.                                                                                                                                        |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3. | Some instructions are multi-word instructions. The extra words of these instructions will be executed as a NOP unless the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program memory locations have a valid instruction. |
| 4. | f <sub>s</sub> and f <sub>d</sub> do not cover the full memory range. 2 MSbs of bank selection are forced to 0b00 to limit the range of these instructions to the lower 4k addressing space.                                                                                          |
|    |                                                                                                                                                                                                                                                                                       |
|    |                                                                                                                                                                                                                                                                                       |
|    |                                                                                                                                                                                                                                                                                       |

| continued |                                           |                                     |        |      |               |      |        |          |       |  |  |
|-----------|-------------------------------------------|-------------------------------------|--------|------|---------------|------|--------|----------|-------|--|--|
| Mnemo     |                                           |                                     |        |      | 16-Bit Instru |      | Status |          |       |  |  |
| Operar    | nds                                       | Description                         | Cycles | MSb  |               |      | LSb    | Affected | Notes |  |  |
| XORLW     | k                                         | Exclusive OR literal with WREG      | 1      | 0000 | 1010          | kkkk | kkkk   | Z, N     |       |  |  |
|           | DATA MEMORY - PROGRAM MEMORY INSTRUCTIONS |                                     |        |      |               |      |        |          |       |  |  |
| TBLRD*    | _                                         | Table Read                          | 2      | 0000 | 0000          | 0000 | 1000   | None     |       |  |  |
| TBLRD*+   | _                                         | Table Read with post-<br>increment  | 2      | 0000 | 0000          | 0000 | 1001   | None     |       |  |  |
| TBLRD*-   | _                                         | Table Read with post-<br>decrement  | 2      | 0000 | 0000          | 0000 | 1010   | None     |       |  |  |
| TBLRD+*   | _                                         | Table Read with pre-<br>increment   | 2      | 0000 | 0000          | 0000 | 1011   | None     |       |  |  |
| TBLWT*    | _                                         | Table Write                         | 2      | 0000 | 0000          | 0000 | 1100   | None     |       |  |  |
| TBLWT*+   | _                                         | Table Write with post-<br>increment | 2      | 0000 | 0000          | 0000 | 1101   | None     |       |  |  |
| TBLWT*-   | _                                         | Table Write with post-<br>decrement | 2      | 0000 | 0000          | 0000 | 1110   | None     |       |  |  |
| TBLWT+*   | _                                         | Table Write with pre-<br>increment  | 2      | 0000 | 0000          | 0000 | 1111   | None     |       |  |  |
| Notoci    |                                           |                                     |        |      |               |      |        |          |       |  |  |

## Notes:

1. When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

**Instruction Set Summary**